package com.heima.admin.service.impl;

import com.heima.admin.dao.AdUserDao;
import com.heima.admin.service.AdUserService;
import com.heima.model.admin.dto.AdUserDto;
import com.heima.model.admin.entity.AdUser;
import com.heima.model.common.dtos.ResponseResult;
import com.heima.model.common.enums.AppHttpCodeEnum;
import com.heima.utils.common.AppJwtUtil;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * 管理员用户信息表(AdUser)表服务实现类
 *
 * @author makejava
 * @since 2022-04-22 14:38:46
 */
@Service("adUserService")
public class AdUserServiceImpl implements AdUserService {
    @Resource
    private AdUserDao adUserDao;

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    @Override
    public AdUser queryById(Long id) {
        return this.adUserDao.queryById(id);
    }

    /**
     * 查询多条数据
     *
     * @param offset 查询起始位置
     * @param limit  查询条数
     * @return 对象列表
     */
    @Override
    public List<AdUser> queryAllByLimit(int offset, int limit) {
        return this.adUserDao.queryAllByLimit(offset, limit);
    }

    /**
     * 新增数据
     *
     * @param adUser 实例对象
     * @return 实例对象
     */
    @Override
    public AdUser insert(AdUser adUser) {
        this.adUserDao.insert(adUser);
        return adUser;
    }

    /**
     * 修改数据
     *
     * @param adUser 实例对象
     * @return 实例对象
     */
    @Override
    public AdUser update(AdUser adUser) {
        this.adUserDao.update(adUser);
        return this.queryById(adUser.getId());
    }

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    @Override
    public boolean deleteById(Long id) {
        return this.adUserDao.deleteById(id) > 0;
    }

    @Override
    public ResponseResult login(AdUserDto dto) {
        //1. 校验参数
        if (StringUtils.isBlank(dto.getName()) || StringUtils.isBlank(dto.getPassword())) {
            return ResponseResult.errorResult(AppHttpCodeEnum.PARAM_REQUIRE);
        }
        //2. 根据用户输入的用户名查询数据库用户信息  WmUser
        AdUser adUser = adUserDao.findByUsername(dto.getName());
        if (adUser == null) {
            return ResponseResult.errorResult(AppHttpCodeEnum.PARAM_REQUIRE, "用户名错误");
        }

        //3. 使用数据库保存的盐 + 用户输入的密码 加密得到密文 , 使用密文和数据库中的密文进行比对
        String pwd = DigestUtils.md5Hex(dto.getPassword() + adUser.getSalt());
        if (!StringUtils.equals(pwd, adUser.getPassword())) {
            return ResponseResult.errorResult(AppHttpCodeEnum.LOGIN_PASSWORD_ERROR);
        }
        //4. 使用JWT生成TOKEN ,返回数据
        String token = AppJwtUtil.getToken(adUser.getId());

        Map<String, Object> result = new HashMap<>();

        adUser.setSalt("");
        adUser.setPassword("");

        result.put("user", adUser);
        result.put("token", token);

        return ResponseResult.okResult(result);
    }
}
